FSPR (FSPro)
FSPro is a probabilistic two-dimensional fire spread model used as a strategic decision aid tool looking at fire progression risk as it is determined by uncertainty in the fire environment.
-
For more information about the model see the WFDSS FSPro Overview Help Topic.
-
Fire behavior calculations produced with the command line applications developed by the Missoula Fire Sciences Laboratory, Missoula, MT.
To run the FSPro model in the FMSF, there are three required and one optional input:
-
A fuelscape GeoTIFF
-
An input file
-
An ignition shapefile
-
A barrier shapefile (optional)
GeoTIFF
The FSPro model requires a GeoTIFF landscape/fuelscape. The GeoTIFF is uploaded to the FMSF, prior to making a run request (see Upload a GeoTIFF), and the ID is used when making the model run request (see Run a Model).
The following bands must be present in the GeoTIFF in this order (additional bands may exist starting with #9):
Band # |
Band Name |
Units |
---|---|---|
1 |
Elevation (DEM) |
meters |
2 |
Slope |
degrees |
3 |
Aspect |
degrees |
4 |
Fuel Model |
categorical |
5 |
Canopy Cover |
percent |
6 |
Canopy Height |
meters * 10 |
7 |
Canopy Base Height |
meters * 10 |
8 |
Canopy Bulk Density |
kg/m3 * 100 |
Current cell limits for FSPro within the FMSF is 2,500,00. If you are unsure how many cells comprise the GeoTIFF you are using to run the model, Retrieve Minimum Model Run Resolution for a GeoTIFF can be used to determine both the cell counts and the minimum resolution the model may be run.
Ignition & Barrier Shapefiles
FSPro also uses two spatial inputs: ignition shapefile (required) and barrier shapefile (optional). Best practices dictate these files should be in the same projection and coordinate system as the GeoTIFF landscape but that is not a requirement.
To use a shapefile, it must be uploaded to the system prior to attempting to run the model as the assigned ID is used to specify which file to use. For details on shapefile functionality in the FMSF see the Shapefile Functionality section.
The geometry type of an ignition shapefile can be polygon or polyline. Point and multipoint file types will result in a failure.
The geometry of a barrier shapefile can be polygon or polyline.
Input File
The various input and output switches included in the input file (*.txt or *.input) passed to the FMSF are documented in the following sections with the valid ranges for each switch.
Example FSPro input file including all the input and output switches.
Model Setting Switches
Duration: 11
NumFires: 2000
MaxLag: 30
PolyDegree: 9
SavePerimeters: 1
Duration: X where X is an integer representing the number of days to simulate each fire in the run. This includes any forecast days.
-
NOTE: Duration cannot be greater than the number of days in the historical weather stream minus the number of days within the current weather stream.
-
Valid range: 1-14
NumFires: X where X is an integer representing the number of fires to simulate.
-
Valid range: 1-2000
MaxLag: X where X is the number of days of historical ERC information used to calculate the ERC regression to the mean that occurs during modeling.
-
NOTE: MaxLag cannot be greater than NumWxCurrYear.
-
Valid range: 1-364
PolyDegree: X where X is the number of degrees of fit used to generate the polynomial that defines the ERC regression to the mean that occurs during modeling.
-
Valid range: 0-15
SavePerimiters: X where X is an integer Boolean value (0 or 1) that specifies whether the perimeters should be saved in a shapefile.
Wind Switches
CalmValue: 2.52
NumWindDirs: 8
45 90 135 180 225 270 315 360
NumWindSpeeds: 5
3 6 9 12 15
WindCellValues:
6.03 1.81 1.88 2.70 12.45 12.14 3.18 2.77
1.04 0.96 1.14 2.27 15.71 7.76 0.87 0.96
0.08 0.06 0.02 0.14 2.49 0.41 0.08 0.07
0.01 0.01 0.02 0.01 0.32 0.03 0.00 0.02
0.00 0.00 0.00 0.00 0.00 0.01 0.00 0.00
CalmValue: X where X is a floating-point number representing the proportion of winds which will be calm (0 MPH).
-
NOTE: The CalmValue combined with the WindCellValues are normalized to percentages with three decimal points of precision when FSPro is run. The normalized values are accessible in the FSPro input file that is returned with the requested FSPro outputs.
-
Valid range: 0-100
NumWindDirs: X where X is an integer representing the number wind directions within the wind direction matrix. Immediately following this line should be the matrix.
-
Valid range: 4-8
Wind direction matrix must include a single line with X values space delimited:
-
Azimuth of the 20 ft wind
-
Valid range: 0-360
-
NumWindSpeeds: X where X is an integer representing the number wind speeds within the wind speed matrix. Immediately following this line should be X space delimited wind speeds in ascending order.
-
Valid range: 1-10
Wind speed matrix must include a single line with X values space delimited:
-
20 ft wind speed in MPH
-
Valid range: 0-200
-
WindCellValues: is the header for the wind direction matrix and a wind speed matrix. Immediately following this line is a matrix where each value represents the proportion of the wind speed/direction occurrence to be used in the simulation.
The wind cell matrix includes NumWindDirs: X columns by NumWindSpeeds: X lines with NumWindDirs: X space delimited values.
-
Proportion of the wind speed/wind direction occurrence
-
Valid range: >0
-
ERC Classes
NumERCClasses: 5
76 82 3.8 4.3 6.2 38.2 67.1 360 0.15 10
68 76 4.4 5.0 7.1 44.7 72.7 300 0.1 0
61 68 4.5 5.1 7.5 58.2 84.3 240 0.05 0
54 61 5.0 5.8 8.8 70.7 95.1 180 0.01 0
46 54 6.0 7.8 10.1 75.5 99.3 120 0.0 0
NumERCClasses: X where X an integer representing the number of ERC classes used in the simulation. Immediately following this line should be X lines of ERC class definitions, in descending order by ERC value.
-
Valid range: 1-10
ERC class entries must include the following 10 values in order, per line, space delimited:
-
Minimum ERC value
-
NOTE: ERC classes cannot overlap. Except for the first class, the minimum value of the first class should be the same as the maximum value of the next class.
-
Valid range: 0-250
-
-
Maximum ERC value
-
Valid range: 0-250
-
-
1-hr dead fuel moisture content percent
-
Valid range: 2-300
-
-
10-hr dead fuel moisture content percent
-
Valid range: 2-300
-
-
100-hr dead fuel moisture content percent
-
Valid range: 2-300
-
-
Live herbaceous fuel moisture content percent
-
Valid range: 2-300
-
-
Live woody fuel moisture content percent
-
Valid range: 2-300
-
-
Burn period (in minutes)
-
Valid range: 0-1440
-
-
Spotting probability
-
Valid range: 0-1
-
-
Spotting delay (in minutes)
-
Valid range: 0-60
-
Historical ERC Stream Switches
NumERCYears: 13
NumWxPerYear: 227
HistoricERCValues:
0 0 0 5 2 0 6 10 0 10 0 0 2 4 9 0 4 11 12 ... 43
0 0 2 4 3 0 0 0 0 0 5 0 0 3 7 11 13 13 4 ... 23
0 0 0 4 6 0 0 0 3 0 1 4 7 12 15 20 15 15 ... 36
...
0 0 0 0 0 0 0 0 0 5 8 12 15 11 15 15 8 0 0 ... 32
AvgERCValues:
5.31 5.31 5.25 7.77 6.38 3.77 2.0 4.0 3.08 ... 20.91
StdDevERCValues:
9.58 8.55 6.54 8.76 9.17 6.61 3.79 4.61 ... 14.01
NumERCYears: X where X is an integer representing the number of years of historic ERC streams.
-
Valid range: 1-100
NumWxPerYear: X where X is an integer representing the number of ERC values present in each historic ERC stream.
-
Valid range: 30-365
HistoricERCValues: is the header for the historic ERC value matrix. Immediately following this line is the matrix.
The historic ERC matrix is NumERCYears lines of NumWxPerYear space delimited values.
-
Historic ERC value
-
Valid range: 0-250
-
AvgERCValues: is the header for the average ERC values matrix. Immediately following this line is the matrix.
The average ERC matrix is a single line of NumWxPerYear space delimited values.
-
Average ERC value
-
NOTE: The average ERC value cannot be greater than the largest value in the HistoricERCValues matrix. If this occurs an error is returned.
-
Valid range: 0-250
-
StdDevERCValues: is the header for the standard deviation ERC values matrix. Immediately following this line is the matrix.
The standard deviation ERC matrix is a single line of NumWxPerYear space delimited values.
-
Valid range: 0-3/5th of the maximum value in the HistoricERCValues
Current ERC Stream Switches
NumWxCurrYear: 145
CurrentERCValues:
0 0 0 0 0 0 0 0 0 5 8 12 15 11 15 ... 84
NumWxCurrYear: X where X is the number of ERC values for the current year leading up to ignition.
-
NOTE: X should be greater than or equal to MaxLag and less than NumWXPerYear minus Duration.
-
Valid range: 0-364
CurrentERCValues: is the header for the current ERC values matrix. Immediately following this line is the matrix.
The current ERC matrix is a single line of NumWxCurrYear space delimited values.
-
Current ERC value
-
Valid range: 0-250
-
Forecast Switches
The forecast switches are optional. If used, every fire simulation run by the model will use the same ERC value, wind speed, and wind direction for the first N days of the modeling where N is the number of forecasts.
NumForecast: 2
75 3 304
77 8 210
NumForecast: X where X is an integer representing the number of forecast days to be used for each fire in the simulation. Immediately following this line is the number of forecast days matrix.
-
Valid range: 0-30
Number of forecast days must include the following 3 integers in order per line, space, or tab delimited:
-
ERC
-
Valid range: 0-250
-
-
20 ft wind speed in MPH at the time of the record
-
Valid range: 0-100
-
-
Azimuth of the 20 ft wind at the time of the record
-
Valid range: 0-360
-
Canopy Characteristic Switches
CROWN_FIRE_METHOD: Finney
CROWN_FIRE_METHOD: cfmethod where cfmethod is either ‘ScottReinhardt’ or ‘Finney’.
-
Valid range: ScottReinhardt, Finney
Spotting Switches
SPOTTING_SEED: 863039
SPOTTING_SEED: X where X is typically a randomly generated value; however, it can be specified in the input file.
-
Valid range: 0-999999
Barrier Fill Switch
MTT_FILL_BARRIERS: 1
MTT_FILL_BARRIERS: X where X is either 1 for true or 0 for false.
-
Valid range: 0,1
Output Switches
PROBABILITY_GRID:
ARRIVAL_TIME:
AVERAGE_FLAMELENGTH:
FSPROTIMINGS:
The FSPro fire behavior model will produce up to five gridded output layers as well as seven non-gridded output types.
Outputs are requested by using the appropriate switch(s) in the input file. For gridded outputs, the order the switch(s) are listed in the input file correlate to the band order in the output GeoTIFF.
Grid outputs (part of the multi-band GeoTIFF)
Switch |
Output Layer |
Units |
---|---|---|
PROBABILITY_GRID: |
FSPro Probability Grid |
probability |
ARRIVAL_TIME: |
FSPro Arrival Time |
days |
AVERAGE_FLAMELENGTH: |
FSPro Average Flame Length |
meters |
SUPPRESSION_EFFECT: |
FSPro Suppression Effect |
probability |
IGNITION: |
FSPro Ignition Grid |
class |
Non-grid outputs
Switch |
Description |
---|---|
FSPROARRIVAL: |
Shapefile that contains the burn probability that a fire burned the cell on the given day |
FSPROPERIMETERS: |
Shapefile that contains the perimeters for each simulation |
FSPROEVENTCOVERAGE: |
Text file of the expected versus observed occurrences of ERC values and wind conditions |
FSPRODAILYACRES: |
Text file of the number of acres burned for each day of each simulated fire |
FSPRODAYTYPES: |
CSV file of the FlamMap run scenarios |
FSPROFIRESTREAMS: |
Text file of the fire number and day types used for each of the fires |
FSPROTIMINGS: |
Text file that simulation information related to the FSPro run |
FSPROCONTAINSUMMARY: |
Text file that summaries the containment probability |
Switches Not Currently Supported by the FMSF
The FMSF does not currently support all switches available within the FSPro model. Those not supported are listed below.
CUSTOM_FUELS_FILE: Filename where filename is the name of the desired custom fuels file to use.
-
The FMSF does not support custom fuel models currently.